#!/usr/bin/env python3

import os
import subprocess
import json

# Initialize variables from environment
cluster_name = os.environ['cluster-name']
infra_env = os.environ['infra-env']
rack_ns = os.environ['rack-ns']
bb_repo = os.environ['ocp-neptune-artifacts-repo']
datacenter = os.environ['datacenter']

# Path to the cluster_vars.yaml file
output_path = f"/workspace/output/{bb_repo}/{datacenter}/{cluster_name}/cluster_vars.yaml"

# Function to fetch machine details (name, bmc_ip, and host_ip) from the rack
def fetch_machine_details():
    # Fetch the machine names, BMC IPs, and host IPs from the rack resource
    result = subprocess.run(['oc', 'get', 'rack', infra_env, '-n', rack_ns, '-o', 'json'], stdout=subprocess.PIPE)
    
    if result.returncode != 0:
        print(f"Failed to get rack details: {result.stderr.decode('utf-8')}")
        return []

    try:
        rack = json.loads(result.stdout)
        if 'machines' not in rack['spec'] or not rack['spec']['machines']:
            print("No machines found in the rack.")
            return []
    except Exception as e:
        print(f"Error processing rack details: {e}")
        return []

    machine_details = []
    
    # Extract machine details (name, bmc_ip, host_ip)
    for machine in rack['spec']['machines']:
        name = machine['name']
        bmc_ip = machine['bmc_ip']
        host_ip = machine.get('host_ip')  # Skip if host_ip doesn't exist
        machine_info = {
            'name': name,
            'bmc_ip': bmc_ip,
        }
        if host_ip:
            machine_info['host_ip'] = host_ip
        machine_details.append(machine_info)

    return machine_details

# Fetch Machine Names, BMC IPs, and Host IPs from the ACM hub
machine_details = fetch_machine_details()

# Check if there are existing masters and workers in cluster_vars.yaml
existing_masters = []
existing_workers = []

if os.path.exists(output_path):
    with open(output_path, 'r') as file:
        existing_content = file.read()
        if 'masters:' in existing_content:
            existing_masters = existing_content.split('masters:')[1].split('workers:')[0].strip().split('\n')
        if 'workers:' in existing_content:
            existing_workers = existing_content.split('workers:')[1].strip().split('\n')

# Function to classify machines as masters or workers
def classify_machines(existing_masters, existing_workers, machine_details):
    masters = []
    workers = []

    # Check if any machine names start with 'etcd'
    etcd_found = any(machine['name'].startswith('etcd') for machine in machine_details)

    # If a machine starts with 'etcd', it's a master. Otherwise, follow the first-3-master rule.
    if etcd_found:
        for machine in machine_details:
            if machine['name'].startswith('etcd'):
                masters.append(machine)
            else:
                workers.append(machine)
    else:
        # First 3 are masters, and the rest are workers
        masters_needed = max(0, 3 - len(existing_masters))
        for i in range(min(masters_needed, len(machine_details))):
            masters.append(machine_details[i])
        for i in range(masters_needed, len(machine_details)):
            workers.append(machine_details[i])

    return masters, workers

# Classify the new machines
masters, workers = classify_machines(existing_masters, existing_workers, machine_details)

# Manually build YAML structure as a string
yaml_content = f"""
rack:
  1:
    subnet: subnet_value
    machines:
      masters:
"""

# Add masters to YAML content
for master in masters:
    yaml_content += f"        - name: {master['name']}\n"
    yaml_content += f"          bmc_ip: {master['bmc_ip']}\n"
    if 'host_ip' in master:
        yaml_content += f"          host_ip: {master['host_ip']}\n"

# Add workers to YAML content
yaml_content += "      workers:\n"
for worker in workers:
    yaml_content += f"        - name: {worker['name']}\n"
    yaml_content += f"          bmc_ip: {worker['bmc_ip']}\n"
    if 'host_ip' in worker:
        yaml_content += f"          host_ip: {worker['host_ip']}\n"

# Check if the file already exists
if os.path.exists(output_path):
    with open(output_path, 'a') as file:
        file.write(yaml_content)
    print(f"Updated cluster_vars.yaml with new machines.")
else:
    with open(output_path, 'w') as file:
        file.write(yaml_content)
    print(f"Created cluster_vars.yaml and added new machines.")
